<template>
  <el-dialog
    :visible.sync="visibleModal"
    title="添加自评"
    width="720px"
    :close-on-click-modal="false"
    @close="onCancel"
  >
    <el-form :model="formData" label-width="100px" label-position="right">
      <el-form-item label="商品：">
        <div class="upload-box" v-db-click @click="callGoods">
          <img v-if="goods.id" :src="goods.image" class="image" />
          <i v-else class="el-icon-goods"></i>
        </div>
      </el-form-item>
      <el-form-item v-if="goods.id" label="商品规格：">
        <div class="upload-box" v-db-click @click="callAttr">
          <img v-if="attr.image" :src="attr.image" class="image" />
          <i v-else class="el-icon-plus" />
        </div>
        <div>{{ attr.suk }}</div>
      </el-form-item>
      <el-form-item label="用户头像：">
        <div class="upload-box" v-db-click @click="callPicture('单选')">
          <img v-if="avatar.att_dir" :src="avatar.att_dir" class="image" />
          <i v-if="avatar.att_dir" class="el-icon-error btn" v-db-click @click.stop="removeUser"></i>
          <i v-else class="el-icon-user" />
        </div>
      </el-form-item>
      <el-form-item label="用户名称：">
        <el-input v-model="formData.nickname" placeholder="请输入用户名称" class="w100"></el-input>
      </el-form-item>
      <el-form-item label="评价文字：">
        <el-input v-model="formData.comment" type="textarea" placeholder="请输入评价文字" class="w100"></el-input>
      </el-form-item>
      <el-form-item label="商品分数：">
        <el-rate v-model="product_score" />
      </el-form-item>
      <el-form-item label="服务分数：">
        <el-rate v-model="service_score" />
      </el-form-item>
      <el-form-item label="评价图片：">
        <div class="df-aic">
          <div v-for="item in picture" :key="item.att_id" class="upload-box">
            <img :src="item.att_dir" class="image" />
            <i class="el-icon-error btn" v-db-click @click.stop="removePicture(item.att_id)"></i>
          </div>
          <div v-if="picture.length < 8" class="upload-box" v-db-click @click="callPicture('多选')">
            <i class="el-icon-picture-outline"></i>
          </div>
        </div>
      </el-form-item>
      <el-form-item label="评价时间：">
        <el-date-picker
          clearable
          v-model="add_time"
          type="datetime"
          range-separator="-"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          @change="onChange"
          style="width: 414px"
        />
      </el-form-item>
    </el-form>
    <span slot="footer" class="dialog-footer">
      <el-button v-db-click @click="onCancel">取 消</el-button>
      <el-button type="primary" v-db-click @click="onOk">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
import { saveFictitiousReply } from '@/api/product';
export default {
  props: {
    visible: {
      type: Boolean,
      default: false,
    },
    goods: {
      type: Object,
      default() {
        return {};
      },
    },
    attr: {
      type: Object,
      default() {
        return {};
      },
    },
    avatar: {
      type: Object,
      default() {
        return {};
      },
    },
    picture: {
      type: Array,
      default() {
        return [];
      },
    },
  },
  data() {
    return {
      formData: {
        avatar: '',
        nickname: '',
        comment: '',
      },
      product_score: 5,
      service_score: 5,
      pics: [],
      add_time: '',
      visibleModal: false,
    };
  },
  watch: {
    picture(value) {
      this.pics = value.map((item) => {
        return item.att_dir;
      });
    },
    visible(value) {
      this.visibleModal = value;
      if (!value) {
        this.formData.nickname = '';
        this.formData.comment = '';
        this.product_score = 5;
        this.service_score = 5;
        this.add_time = '';
      }
    },
  },
  methods: {
    removeUser() {
      this.avatar.att_dir = '';
    },
    removePicture(att_id) {
      this.$emit('removePicture', att_id);
    },
    onChange(date) {
      this.add_time = date;
    },
    callGoods() {
      this.$emit('callGoods');
    },
    callAttr() {
      this.$emit('callAttr');
    },
    callPicture(type) {
      this.$emit('callPicture', type);
    },
    onOk() {
      if (!this.goods.id) {
        return this.$message.error('请选择商品');
      }
      if (!this.attr.image) {
        return this.$message.error('请选择商品规格');
      }
      if (!this.avatar.att_dir) {
        return this.$message.error('请选择用户头像');
      }
      if (!this.formData.nickname) {
        return this.$message.error('请填写用户昵称');
      }
      if (!this.formData.comment) {
        return this.$message.error('请填写评论内容');
      }
      if (!this.product_score) {
        return this.$message.error('商品分数必须是1-5之间的整数');
      }
      if (!this.service_score) {
        return this.$message.error('服务分数必须是1-5之间的整数');
      }
      let data = {
        image: {
          image: this.goods.image,
          product_id: this.goods.id,
        },
        suk: this.attr.suk,
        avatar: this.avatar.att_dir,
        nickname: this.formData.nickname,
        comment: this.formData.comment,
        product_score: this.product_score,
        service_score: this.service_score,
        pics: this.pics,
        add_time: this.add_time,
      };
      saveFictitiousReply(data)
        .then((res) => {
          this.$message.success(res.msg);
          this.$emit('close', false);
        })
        .catch((res) => {
          this.$message.error(res.msg);
        });
    },
    onCancel() {
      this.$emit('close', false);
    },
  },
};
</script>

<style lang="stylus" scoped>
.upload-box {
  position: relative;
  display: flex;
  align-items center
  justify-content center
  width: 58px;
  height: 58px;
  border: 1px dashed #c0ccda;
  border-radius: 4px;
  //box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
  vertical-align: middle;
  text-align: center;
  line-height: 58px;
  cursor: pointer;

  + .upload-box {
    margin-left: 10px;
  }

  .ivu-icon {
    vertical-align: middle;
    font-size: 20px;
  }

  .image {
    width: 100%;
    height: 100%;
    border-radius: 3px;
  }

  .btn {
    position: absolute;
    top: 0;
    right: 0;
    font-size: 14px
    transform: translate(50%, -50%);
  }
} .df-aic{
  display flex
  flex-wrap: wrap
}
  .w414{
    width:414px;
  }
</style>
